Skill

Control Flow (নিয়ন্ত্রণ প্রবাহ)

Computer Programming - এল্ম (Elm)
166

Control Flow (নিয়ন্ত্রণ প্রবাহ) in Elm

Elm একটি ফাংশনাল প্রোগ্রামিং ভাষা, যেখানে নিয়ন্ত্রণ প্রবাহ (Control Flow) সাধারণত শর্তমূলক বিবৃতি (Conditional Statements), লুপ, এবং প্যাটার্ন ম্যাচিং এর মাধ্যমে পরিচালিত হয়। যদিও Elm তে সাধারণভাবে লুপ ব্যবহৃত হয় না, কিন্তু রিকার্সন (Recursion) এর মাধ্যমে লুপের মতো কার্যক্রম করা যায়। Elm এ if-else, case expressions, এবং let স্টেটমেন্ট দিয়ে নিয়ন্ত্রণ প্রবাহ নিয়ন্ত্রণ করা হয়।

এখানে Elm এ ব্যবহৃত নিয়ন্ত্রণ প্রবাহের মৌলিক ধারণাগুলি বিস্তারিতভাবে আলোচনা করা হলো।


১. if-else Statements

Elm তে if-else স্টেটমেন্ট ব্যবহার করে শর্তমূলক কার্যক্রম পরিচালনা করা হয়। এতে একটি শর্ত যাচাই করা হয় এবং শর্ত পূর্ণ হলে একটি ব্লক, আর না হলে অন্য একটি ব্লক কার্যকর হয়।

উদাহরণ:

checkNumber : Int -> String
checkNumber x =
    if x > 0 then
        "Positive"
    else if x < 0 then
        "Negative"
    else
        "Zero"

এখানে, checkNumber ফাংশনটি একটি পূর্ণসংখ্যা নেয় এবং তার মানের ভিত্তিতে "Positive", "Negative", বা "Zero" ফেরত দেয়।

কল:

result = checkNumber 5  -- ফলাফল হবে "Positive"

এখানে x যদি ৫ হয়, তাহলে "Positive" ফেরত আসবে।


২. case Expressions

Elm তে case expressions ব্যবহার করে বিভিন্ন ধরনের শর্ত বা প্যাটার্ন পরীক্ষা করা যায়। এটি বিশেষভাবে প্যাটার্ন ম্যাচিং এর জন্য ব্যবহার করা হয়, যেখানে বিভিন্ন ধরণের ভ্যালুর সাথে মেলানো হয়।

উদাহরণ:

describeDay : Int -> String
describeDay day =
    case day of
        1 -> "Monday"
        2 -> "Tuesday"
        3 -> "Wednesday"
        4 -> "Thursday"
        5 -> "Friday"
        6 -> "Saturday"
        7 -> "Sunday"
        _ -> "Invalid day"

এখানে, describeDay ফাংশনটি একটি পূর্ণসংখ্যা (Int) নেয় এবং তা দিয়ে সাপ্তাহিক দিনের নাম প্রদর্শন করে। case এক্সপ্রেশনটি ১ থেকে ৭ পর্যন্ত শর্ত যাচাই করে এবং অন্য যেকোনো মানের জন্য "Invalid day" ফেরত দেয়।

কল:

result = describeDay 3  -- ফলাফল হবে "Wednesday"

এখানে day যদি ৩ হয়, তাহলে "Wednesday" ফলস্বরূপ প্রদান করবে।


৩. let Expressions

Elm তে let expressions ব্যবহার করা হয় ভেরিয়েবল ডিফাইন করার জন্য এবং এটি সাধারণত scope সীমাবদ্ধ করতে সাহায্য করে। এটি ফাংশন বা এক্সপ্রেশনের মধ্যে ভেরিয়েবল সেট করার জন্য ব্যবহৃত হয়।

উদাহরণ:

calculate : Int -> Int -> Int
calculate a b =
    let
        sum = a + b
        product = a * b
    in
        sum + product

এখানে, let ব্লকের মধ্যে sum এবং product ভেরিয়েবল তৈরি করা হয়েছে, যা পরে মূল এক্সপ্রেশনে ব্যবহার করা হয়েছে। sum এবং product এর মান যোগ করে ফাংশনটি ফলাফল প্রদান করবে।

কল:

result = calculate 5 10  -- ফলাফল হবে 75

এখানে a = 5 এবং b = 10 হলে, প্রথমে sum = 15 এবং product = 50 হবে, এবং শেষে তাদের যোগফল 15 + 50 = 75 হবে।


৪. রিকার্সন (Recursion) ব্যবহার করে লুপ

Elm তে সাধারণত লুপ ব্যবহৃত হয় না। তবে, রিকার্সন ব্যবহার করে লুপের মতো কার্যক্রম করা হয়। ফাংশন নিজের মধ্যে নিজেকে কল করে নির্দিষ্ট সংখ্যক বার কার্যক্রম চালায়। এটি ফাংশনাল প্রোগ্রামিং ভাষাগুলোর একটি মৌলিক বৈশিষ্ট্য।

উদাহরণ:

sumList : List Int -> Int
sumList list =
    case list of
        [] -> 0
        x :: xs -> x + sumList xs

এখানে sumList ফাংশনটি একটি পূর্ণসংখ্যার লিস্ট নেয় এবং লিস্টের সব উপাদান যোগ করে। এটি রিকার্সন ব্যবহার করে, যেখানে প্রথমে লিস্টের প্রথম উপাদান যোগ করা হয় এবং পরে বাকী উপাদানগুলোর জন্য পুনরায় sumList কল করা হয়।

কল:

result = sumList [1, 2, 3, 4, 5]  -- ফলাফল হবে 15

এখানে sumList ফাংশনটি [1, 2, 3, 4, 5] লিস্টের সব উপাদান যোগ করে ১৫ প্রদান করবে।


৫. andThen (Chain of Functions)

Elm তে কিছু সময় একটি ফাংশন থেকে অন্য ফাংশনে যাওয়ার জন্য andThen ব্যবহার করা হয়। এটি সাধারণত Result বা Maybe টাইপের ক্ষেত্রে ব্যবহৃত হয়, যেখানে পরবর্তী কার্যক্রম পূর্ববর্তী ফাংশনের ফলাফল অনুযায়ী নির্ভর করে।

উদাহরণ:

divide : Int -> Int -> Result String Int
divide x y =
    if y == 0 then
        Err "Division by zero"
    else
        Ok (x // y)

calculate : Int -> Int -> Int -> Result String Int
calculate x y z =
    divide x y
        |> Result.andThen (\result -> divide result z)

এখানে calculate ফাংশন প্রথমে x এবং y এর মধ্যে ভাগফল বের করবে এবং তারপর সেই ফলাফল দিয়ে পরবর্তী ভাগফল বের করবে।

কল:

result = calculate 10 2 5  -- ফলাফল হবে Ok 1

এখানে, প্রথমে 10 ÷ 2 = 5 এবং তারপর 5 ÷ 5 = 1 হবে।


উপসংহার

Elm এ নিয়ন্ত্রণ প্রবাহের প্রধান উপাদানগুলো হল if-else, case expressions, let expressions, এবং recursion। এসবের মাধ্যমে আমরা শর্তমূলক কার্যক্রম, প্যাটার্ন ম্যাচিং, এবং ফাংশনাল লজিক তৈরি করতে পারি। Elm ফাংশনাল প্রোগ্রামিং ভাষা হওয়ায়, এটি লুপের পরিবর্তে রিকার্সন ব্যবহার করে কার্যক্রম পুনরাবৃত্তি করে।

Content added By

if, else এবং case স্টেটমেন্ট

153

if, else, এবং case স্টেটমেন্ট

Elm একটি ফাংশনাল প্রোগ্রামিং ভাষা, যেখানে সাধারণ if, else এবং case স্টেটমেন্টগুলি ব্যবহার করে শর্তাধীন লজিক (conditional logic) পরিচালনা করা হয়। এগুলি কোডের বিভিন্ন শাখা এবং সিদ্ধান্ত নেয়ার জন্য ব্যবহৃত হয়। এখানে if, else এবং case স্টেটমেন্টের ব্যাবহার এবং তাদের মধ্যে পার্থক্য তুলে ধরা হলো।


১. if এবং else স্টেটমেন্ট

if এবং else স্টেটমেন্টগুলি সাধারণত শর্তাধীন কোড এক্সিকিউশনের জন্য ব্যবহৃত হয়। যদি কোনো শর্ত সত্য (true) হয়, তাহলে if ব্লকটি এক্সিকিউট হয়, অন্যথায় else ব্লকটি এক্সিকিউট হয়।

Sintax:

if condition then
    -- code to execute if condition is true
else
    -- code to execute if condition is false

উদাহরণ:

isEven : Int -> String
isEven n =
    if n % 2 == 0 then
        "Even"
    else
        "Odd"

এখানে isEven ফাংশনটি একটি পূর্ণসংখ্যা নেবে এবং তার উপর শর্ত প্রয়োগ করে চেক করবে যে এটি even না odd। যদি সংখ্যা ২ দিয়ে বিভাজ্য হয় (মানে শর্ত সত্য), তাহলে "Even" রিটার্ন করবে, অন্যথায় "Odd" রিটার্ন করবে।


২. case স্টেটমেন্ট

case স্টেটমেন্টটি সাধারণত pattern matching এর জন্য ব্যবহৃত হয়, যেখানে আপনি একাধিক শর্ত বা ডেটার ধরন অনুসারে ভিন্ন ভিন্ন কোড এক্সিকিউট করতে পারেন। এটি ফাংশনাল ভাষায় বিশেষভাবে শক্তিশালী, কারণ এটি ডেটার বিভিন্ন ধরন অনুযায়ী শর্ত নির্ধারণে সহায়তা করে।

Sintax:

case value of
    pattern1 -> result1
    pattern2 -> result2
    _ -> defaultResult

এখানে value হল সেই মান যা case এর মাধ্যমে পরীক্ষিত হবে, এবং প্রতিটি pattern তার সাথে মেলে এমন শর্ত বা ডেটা ধরন।

উদাহরণ:

describeNumber : Int -> String
describeNumber n =
    case n of
        0 -> "Zero"
        1 -> "One"
        _ -> "Other"

এখানে describeNumber ফাংশনটি একটি পূর্ণসংখ্যা n নেবে এবং তার মানের উপর ভিত্তি করে সঠিক স্ট্রিং রিটার্ন করবে:

  • যদি n ০ হয়, তাহলে "Zero" রিটার্ন করবে।
  • যদি n ১ হয়, তাহলে "One" রিটার্ন করবে।
  • অন্য যেকোনো সংখ্যার জন্য "Other" রিটার্ন করবে।

_ হল একটি wildcard যা অন্য সব মানের জন্য ব্যবহার করা হয়।


৩. if এবং case এর মধ্যে পার্থক্য

  • if সাধারণত কোনো শর্ত পরীক্ষা করার জন্য ব্যবহৃত হয়, যেমন সংখ্যা মুডুলাস চেক করা বা Boolean ভ্যালু পরীক্ষা করা। এটি সাধারণত একক শর্তের জন্য উপযোগী।
  • case একটি ভিন্ন ধরনের শর্ত চেক করার জন্য ব্যবহৃত হয়, যেখানে একাধিক ভিন্ন ভিন্ন শর্ত বা প্যাটার্ন মেলা (pattern matching) করা হয়। এটি ডেটার ধরন বা বিভিন্ন অবস্থা অনুযায়ী কোড এক্সিকিউট করতে সাহায্য করে।

৪. আরও উন্নত উদাহরণ

ifelse উদাহরণ:

checkAge : Int -> String
checkAge age =
    if age >= 18 then
        "Adult"
    else
        "Minor"

এখানে checkAge ফাংশনটি একজন ব্যক্তির বয়সের উপর ভিত্তি করে বলবে সে Adult নাকি Minor

case উদাহরণ:

describeShape : Shape -> String
describeShape shape =
    case shape of
        Circle radius -> "A circle with radius " ++ String.fromInt radius
        Rectangle width height -> "A rectangle with width " ++ String.fromInt width ++ " and height " ++ String.fromInt height
        _ -> "Unknown shape"

এখানে describeShape ফাংশনটি বিভিন্ন ধরনের Shape পরীক্ষা করে:

  • যদি Circle পাওয়া যায়, তাহলে তার রেডিয়াস দেখানো হবে।
  • যদি Rectangle পাওয়া যায়, তাহলে তার প্রস্থ এবং উচ্চতা দেখানো হবে।
  • অন্য যেকোনো ক্ষেত্রে "Unknown shape" রিটার্ন করবে।

উপসংহার

if, else, এবং case স্টেটমেন্টগুলি Elm এ শর্তাধীন কোড এক্সিকিউশনের জন্য ব্যবহৃত হয়, তবে তাদের ব্যবহার এবং প্রাসঙ্গিকতা কিছুটা আলাদা:

  • if সাধারণ শর্তমূলক পরীক্ষা করে একক সিদ্ধান্ত নেয়।
  • case ডেটার ধরন বা প্যাটার্ন অনুযায়ী একাধিক শর্ত পরীক্ষা করে, যা ফাংশনাল প্রোগ্রামিংয়ে খুবই শক্তিশালী।
  • else সাধারণত if এর অংশ হিসেবে ব্যবহৃত হয়, যখন শর্ত মেলে না তখন অন্য একটি কোড ব্লক এক্সিকিউট করতে।

এগুলি ব্যবহার করে আপনি আপনার কোডে কার্যকরী শর্ত নির্ধারণ করতে পারেন।

Content added By

Pattern Matching এর ব্যবহার

143

Pattern Matching এর ব্যবহার

Pattern Matching ফাংশনাল প্রোগ্রামিং ভাষাগুলির একটি গুরুত্বপূর্ণ বৈশিষ্ট্য, এবং Elm ভাষায়ও এটি ব্যাপকভাবে ব্যবহৃত হয়। Pattern Matching এর মাধ্যমে আপনি বিভিন্ন ধরণের ডেটা স্ট্রাকচার (যেমন লিস্ট, টিউপল, কাস্টম ডেটা টাইপ) পরীক্ষা করে তাদের উপর নির্দিষ্ট কাজ করতে পারেন। Elm এর case এক্সপ্রেশন এবং let স্টেটমেন্টে প্যাটার্ন ম্যাচিং ব্যবহৃত হয়।

এখানে Pattern Matching এর ব্যবহারের মৌলিক ধারণা, সিনট্যাক্স এবং কিছু উদাহরণ দেওয়া হলো:


১. Pattern Matching এর মৌলিক ধারণা

Pattern Matching এর মাধ্যমে আপনি একটি ডেটা টাইপের মানের মধ্যে প্যাটার্ন খুঁজে বের করতে পারেন এবং সেই অনুযায়ী আলাদা আলাদা কার্যকলাপ করতে পারেন। এটি একটি শক্তিশালী এবং কনডিশনাল স্টেটমেন্টের বিকল্প হিসেবে কাজ করে, যা কোডকে আরও পরিষ্কার ও কার্যকরী করে তোলে।

২. Pattern Matching এর সিনট্যাক্স

Elm এ case এক্সপ্রেশন ব্যবহার করে প্যাটার্ন ম্যাচিং করা হয়। নিচে এর মৌলিক সিনট্যাক্স দেখানো হলো:

case <expression> of
    <pattern1> -> <expression1>
    <pattern2> -> <expression2>
    ...
    _ -> <default_expression>

এখানে, <expression> হল সেই মান যা আপনি প্যাটার্ন ম্যাচিং করতে চান, এবং প্রতিটি প্যাটার্ন (<pattern1>, <pattern2>, ...) বিভিন্ন ধরণের মানের জন্য ম্যাচ করবে। _ (underscore) হল ডিফল্ট প্যাটার্ন, যা অন্যান্য কোন প্যাটার্নের সাথে না মেলা মানগুলির জন্য ব্যবহৃত হয়।


৩. Pattern Matching এর উদাহরণ

এলেমে একটি সাধারন প্যাটার্ন ম্যাচিং উদাহরণ

ধরা যাক, আমরা একটি পূর্ণসংখ্যা দিয়ে চেক করতে চাই যে এটি ধনাত্মক, ঋণাত্মক, অথবা শূন্য। এর জন্য আমরা case এক্সপ্রেশন ব্যবহার করতে পারি:

checkNumber : Int -> String
checkNumber n =
    case n of
        0 -> "Zero"
        _ -> if n > 0 then "Positive" else "Negative"

এখানে, checkNumber ফাংশনটি একটি পূর্ণসংখ্যা নেয় এবং তার উপর ভিত্তি করে একটি স্ট্রিং রিটার্ন করে। case n of অংশে প্রথমে 0 এর সাথে ম্যাচ করা হচ্ছে, পরে অন্য কোন মানের জন্য _ (ডিফল্ট প্যাটার্ন) ব্যবহৃত হচ্ছে, যা শর্তমাফিক "Positive" বা "Negative" রিটার্ন করবে।

লিস্টে প্যাটার্ন ম্যাচিং

লিস্টের উপাদানগুলির উপর প্যাটার্ন ম্যাচিং খুবই সাধারণ। আপনি একটি লিস্টের প্রথম উপাদান এবং বাকি উপাদানগুলির উপর কাজ করতে পারেন:

sumList : List Int -> Int
sumList lst =
    case lst of
        [] -> 0  -- যদি লিস্টটি খালি হয়
        x :: xs -> x + sumList xs  -- প্রথম উপাদান যোগ করা

এখানে, sumList ফাংশনটি একটি পূর্ণসংখ্যা লিস্ট নেয় এবং তার সমস্ত উপাদান যোগ করে একটি পূর্ণসংখ্যা রিটার্ন করে। [] প্যাটার্নটি একটি খালি লিস্টের জন্য, এবং x :: xs প্যাটার্নটি একটি নন-খালি লিস্টের প্রথম উপাদান x এবং বাকি উপাদানগুলো xs গ্রহণ করে।

কাস্টম ডেটা টাইপে প্যাটার্ন ম্যাচিং

Elm এ কাস্টম ডেটা টাইপ (যেমন type alias বা union type) তৈরির পরও প্যাটার্ন ম্যাচিং ব্যবহার করা যায়। ধরুন, আমরা একটি কাস্টম ডেটা টাইপ Result তৈরি করি, যা সফল এবং ব্যর্থ উভয় ফলাফল ধারণ করতে পারে:

type Result = Success String | Failure String

handleResult : Result -> String
handleResult result =
    case result of
        Success msg -> "Success: " ++ msg
        Failure msg -> "Failure: " ++ msg

এখানে, handleResult ফাংশনটি Result টাইপের একটি মান নেয় এবং Success বা Failure এর উপর ভিত্তি করে একটি স্ট্রিং রিটার্ন করে। প্যাটার্ন ম্যাচিং এখানে Success এবং Failure কনস্ট্রাক্টরের উপর করা হচ্ছে।

Multiple Patterns Matching

আপনি একাধিক প্যাটার্নও একসাথে ম্যাচ করতে পারেন, উদাহরণস্বরূপ:

describeNumber : Int -> String
describeNumber n =
    case n of
        0 -> "Zero"
        1 -> "One"
        2 -> "Two"
        _ -> "Other"

এখানে, describeNumber ফাংশনটি n এর মানের উপর ভিত্তি করে বিভিন্ন আউটপুট প্রদান করছে। _ প্যাটার্নটি অন্যান্য কোন মানের জন্য ব্যবহৃত হচ্ছে, যা একাধিক প্যাটার্নের সাথে মেলে না।


৪. Pattern Matching এর সুবিধা

  1. কোডের পরিষ্কারতা: Pattern Matching কোডকে অনেক পরিষ্কার এবং সংক্ষিপ্ত করে তোলে, কারণ আপনি একাধিক শর্তের জন্য আলাদা আলাদা ব্লক তৈরি করতে পারেন।
  2. ডেটা স্ট্রাকচার পরীক্ষা: Pattern Matching এর মাধ্যমে আপনি সহজেই লিস্ট, টিউপল, টাইল্ড বা কাস্টম ডেটা টাইপের উপাদান পরীক্ষা করতে পারেন এবং তার উপর কার্যকরী লজিক প্রয়োগ করতে পারেন।
  3. ডিফল্ট কেস: _ প্যাটার্ন ব্যবহার করে আপনি ডিফল্ট কেস বা অন্য সকল মানের জন্য লজিক তৈরি করতে পারেন, যা আপনাকে আরো শক্তিশালী কন্ডিশনাল কোড লিখতে সহায়তা করে।
  4. ফাংশনাল প্রোগ্রামিংয়ের সুবিধা: Pattern Matching ফাংশনাল প্রোগ্রামিং ভাষার একটি মৌলিক ধারণা, এবং এটি ডেভেলপারদের কোডে ভুল কমানোর সুযোগ দেয়।

উপসংহার

Pattern Matching Elm ভাষায় একটি অত্যন্ত শক্তিশালী এবং প্রয়োজনীয় বৈশিষ্ট্য। এটি ডেটা স্ট্রাকচার, বিশেষ করে কাস্টম ডেটা টাইপ এবং লিস্টের উপাদানগুলির উপর কার্যকরীভাবে কাজ করতে সাহায্য করে। Pattern Matching ব্যবহারের মাধ্যমে কোড আরও সংক্ষিপ্ত, পরিষ্কার, এবং কার্যকরী হয়। এটি কোডে ভুল কমাতে সহায়তা করে এবং ফাংশনাল প্রোগ্রামিংয়ের পদ্ধতিতে লিখিত অ্যাপ্লিকেশনগুলিকে আরও শক্তিশালী করে তোলে।

Content added By

let এবং in এর মাধ্যমে স্থানীয় ভেরিয়েবল ডিক্লারেশন

130

Elm এ let এবং in এর মাধ্যমে স্থানীয় ভেরিয়েবল ডিক্লারেশন

Elm ভাষায়, let এবং in ব্যবহার করে স্থানীয় ভেরিয়েবল ডিক্লেয়ার করা হয়। এই কৌশলটি সাধারণত যখন আপনি কিছু অস্থায়ী মান বা হিসাব সংক্রান্ত কাজ করতে চান, তখন ব্যবহার করা হয়। let ব্লকে স্থানীয়ভাবে ভেরিয়েবল ডিফাইন করা হয় এবং সেই ভেরিয়েবলগুলি শুধুমাত্র in ব্লকের ভিতরে ব্যবহারযোগ্য হয়। এটি কোডকে আরও পরিষ্কার এবং সংগঠিত রাখতে সাহায্য করে।


১. let এবং in এর ব্যবহার

let এবং in ফাংশনাল প্রোগ্রামিং ভাষায় সাধারণত এমনভাবে ব্যবহৃত হয়, যাতে আপনি স্থানীয়ভাবে ভেরিয়েবল ডিফাইন করে সেগুলি ব্যবহার করতে পারেন। let ব্লকে আপনি ভেরিয়েবল বা ফাংশন ডিফাইন করেন এবং in এর মাধ্যমে সেই ডিফাইনড ভেরিয়েবলগুলো ব্যবহার করতে পারেন।


২. ভেরিয়েবল ডিক্লারেশন উদাহরণ

এখানে let এবং in এর মাধ্যমে স্থানীয়ভাবে ভেরিয়েবল ডিক্লেয়ার করার একটি উদাহরণ দেওয়া হলো:

sum : Int -> Int -> Int
sum a b =
    let
        x = a + b
        y = x * 2
    in
    y

এখানে:

  • let ব্লকের মধ্যে x এবং y নামে দুটি ভেরিয়েবল ডিফাইন করা হয়েছে।
  • x হল a + b এর যোগফল।
  • y হল x * 2
  • in এর মাধ্যমে, আমরা y ভেরিয়েবলটি রিটার্ন করছি, যা আমাদের ফাংশনের ফলাফল।

৩. একাধিক ভেরিয়েবল ডিফাইন করা

আপনি একাধিক ভেরিয়েবল let ব্লকে ডিফাইন করতে পারেন, এবং তাদেরকে একে একে in এর মধ্যে ব্যবহার করতে পারেন। উদাহরণস্বরূপ:

calculate : Int -> Int -> Int -> Int
calculate a b c =
    let
        x = a + b
        y = b * c
        z = x - y
    in
    z

এখানে:

  • প্রথমে x এবং y নামক দুটি ভেরিয়েবল ডিফাইন করা হয়েছে।
  • পরে z ভেরিয়েবল তৈরি করা হয়েছে, যা x - y এর মান রাখে।
  • সবশেষে in ব্লকের মাধ্যমে z রিটার্ন করা হচ্ছে।

৪. ফাংশন ব্যবহার করা let ব্লকে

এছাড়া, আপনি let ব্লকে ফাংশনও ডিফাইন করতে পারেন এবং সেগুলোকে in ব্লকের মধ্যে ব্যবহার করতে পারেন:

applyDiscount : Float -> Float -> Float
applyDiscount price discount =
    let
        calculateDiscount = price * discount
        finalPrice = price - calculateDiscount
    in
    finalPrice

এখানে:

  • calculateDiscount ফাংশনটি price এবং discount এর গুণফল হিসাব করে।
  • তারপর, finalPrice ভেরিয়েবলটি সেই ডিসকাউন্ট বাদ দিয়ে মোট মূল্য বের করে।
  • in ব্লকে finalPrice রিটার্ন করা হয়।

৫. let এবং in এর সুবিধা

  1. অস্থায়ী ভেরিয়েবল ব্যবহার: let এবং in এর মাধ্যমে আপনি কেবলমাত্র নির্দিষ্ট কোড ব্লক বা ফাংশনে প্রয়োজনীয় অস্থায়ী ভেরিয়েবল ব্যবহার করতে পারবেন, যা কোডকে পরিষ্কার এবং সংগঠিত রাখে।
  2. কোডের পুনঃব্যবহারযোগ্যতা: স্থানীয়ভাবে ডিফাইন করা ভেরিয়েবলগুলো একসাথে ব্যবহৃত হতে পারে এবং সেগুলির প্রভাব শুধুমাত্র নির্দিষ্ট ব্লকের মধ্যে থাকে, যা কোডের পুনঃব্যবহারযোগ্যতা বৃদ্ধি করে।
  3. বিপরীত প্রভাব কমানো: let এবং in ব্যবহারের মাধ্যমে একক ব্লকের মধ্যে ডিফাইনড ভেরিয়েবলগুলি শুধুমাত্র সেই ব্লকেই কার্যকর থাকে, ফলে বাইরে থেকে কোনো প্রভাব পড়বে না।

উপসংহার

Elmlet এবং in ব্যবহার করে আপনি স্থানীয়ভাবে ভেরিয়েবল ডিক্লেয়ার করতে পারেন, যা আপনাকে অস্থায়ী মানগুলি কোডের একটি নির্দিষ্ট অংশে ব্যবহারের সুযোগ দেয়। এটি কোডকে আরো পরিষ্কার এবং সঠিকভাবে সংগঠিত করতে সাহায্য করে এবং কেবলমাত্র প্রয়োজনীয় স্কোপে ভেরিয়েবলগুলোর প্রভাব সীমাবদ্ধ রাখে।

Content added By

Nested Conditions এবং Guards এর প্রয়োগ

163

Nested Conditions এবং Guards এর প্রয়োগ

ElmNested Conditions এবং Guards দুটি শক্তিশালী কনসেপ্ট, যা কোডে শর্ত ভিত্তিক সিদ্ধান্ত গ্রহণ করতে ব্যবহৃত হয়। এই দুটি বৈশিষ্ট্য একে অপরের সাথে সম্পর্কিত হলেও তাদের ব্যবহারের পদ্ধতি এবং প্রয়োগ আলাদা। এখানে আমরা Nested Conditions এবং Guards এর ধারণা, তাদের ব্যবহার এবং প্রয়োগ নিয়ে আলোচনা করব।


১. Nested Conditions (নেস্টেড কন্ডিশন)

Nested Conditions হল শর্তের মধ্যে শর্ত। একাধিক শর্তের ভিত্তিতে কোডের ভিন্ন ভিন্ন অংশে সিদ্ধান্ত নিতে হলে আমরা nested conditions ব্যবহার করি। একেকটি শর্তের মধ্যে আবার নতুন শর্ত থাকতে পারে, অর্থাৎ যদি প্রথম শর্তটি সঠিক না হয়, তাহলে দ্বিতীয় শর্তটি চেক করা হয়।

উদাহরণ: Nested Conditions

ধরা যাক, আমাদের একটি ফাংশন আছে যা পরীক্ষা করবে একটি নম্বর সঠিক পরিসরে আছে কিনা, এবং সেই অনুযায়ী বার্তা দেখাবে:

checkNumber : Int -> String
checkNumber x =
    if x > 0 then
        if x < 10 then
            "Positive number less than 10"
        else
            "Positive number 10 or more"
    else
        if x == 0 then
            "Zero"
        else
            "Negative number"

এখানে, প্রথম if শর্তটি চেক করছে যে x 0 এর চেয়ে বড় কি না। যদি সঠিক হয়, তখন দ্বিতীয় if শর্ত চেক করা হবে, যা নির্ধারণ করবে যে x 10 এর চেয়ে ছোট কি না। যদি প্রথম শর্তটি মিথ্যা হয়, তবে দ্বিতীয় শর্তে গিয়ে জানাবে x শূন্য নাকি নেতিবাচক সংখ্যা।

এই ধরনের শর্তের মধ্যে শর্ত পদ্ধতি Nested Conditions নামে পরিচিত।


২. Guards (গার্ডস)

Guards হল শর্তবিশেষ যা সাধারণত ফাংশন ডিফিনিশনে ব্যবহৃত হয় এবং এগুলির সাহায্যে ফাংশনটির নির্দিষ্ট অংশ চালানোর জন্য শর্ত দেয়া হয়। Guards ব্যবহৃত হয় Pattern Matching এর সাথে এবং এর মাধ্যমে আমরা কোডের প্রবাহ নিয়ন্ত্রণ করতে পারি। এই ধরনের শর্ত সহজে স্পষ্ট এবং পরিষ্কার কোড লেখা সম্ভব করে।

Guards এর সিনট্যাক্স:

functionName argument
    | condition1 = result1
    | condition2 = result2
    | condition3 = result3

এখানে, প্রতিটি শর্ত (guard) আলাদা করে লেখা হয় এবং একেকটি শর্তের জন্য আলাদা রেজাল্ট নির্ধারণ করা হয়।

উদাহরণ: Guards এর ব্যবহার

checkNumber : Int -> String
checkNumber x
    | x > 0 = "Positive number"
    | x == 0 = "Zero"
    | x < 0 = "Negative number"

এখানে, Guards ব্যবহৃত হয়েছে যাতে x এর মান অনুযায়ী উপযুক্ত বার্তা ফিরিয়ে দেওয়া যায়। প্রথম শর্তে চেক করা হয়েছে যে x ধনাত্মক কিনা, দ্বিতীয় শর্তে শূন্য কিনা এবং তৃতীয় শর্তে নেতিবাচক কিনা। Guards এর সাহায্যে কোডটি অনেক বেশি পরিষ্কার এবং সংক্ষিপ্ত হয়েছে।


৩. Nested Conditions বনাম Guards

এখন, আসুন দেখি Nested Conditions এবং Guards এর মধ্যে পার্থক্য কেমন:

বৈশিষ্ট্যNested ConditionsGuards
কোডের পাঠযোগ্যতাকোডের স্ট্রাকচার জটিল হতে পারে যখন শর্তগুলো একে অপরের মধ্যে嵯Guards বেশি পরিষ্কার এবং সহজে পড়া যায়, কারণ শর্তগুলো আলাদা সেকশনে থাকে।
স্টাইলস্ট্যাটিক শর্ত দিয়ে লজিক তৈরি হয়Pattern matching ভিত্তিক শর্ত এবং লজিক তৈরি হয়।
ব্যবহারযোগ্যতাছোট এবং সহজ শর্তের জন্য উপযুক্তঅনেক শর্ত একসাথে বা বড় কোডের জন্য Guards ব্যবহার করা ভালো।

৪. Guards এর আরো উদাহরণ

isPrime : Int -> String
isPrime n
    | n < 2 = "Not prime"
    | n == 2 = "Prime"
    | n % 2 == 0 = "Not prime"
    | otherwise = "Prime"

এখানে, আমরা একটি prime number চেক করার জন্য গার্ড ব্যবহার করেছি। প্রথম গার্ড চেক করে যে n ২ এর কম কি না, দ্বিতীয় গার্ড চেক করে n কি ২, তৃতীয় গার্ড চেক করে যে এটি ২ এর গুণফল কি না, এবং শেষের গার্ডটি ডিফল্টভাবে "Prime" ফেরত দেয়।


উপসংহার

Nested Conditions এবং Guards উভয়ই শর্তভিত্তিক কোড নিয়ন্ত্রণের জন্য ব্যবহৃত হয়, তবে Guards বেশিরভাগ সময় পরিষ্কার এবং আরো কার্যকরী কারণ এটি কোডকে আরো সুসংগঠিত করে। Guards সাধারণত ফাংশনাল প্রোগ্রামিং ভাষায় ব্যবহৃত হয় এবং Pattern Matching এর সাথে মিলে। যখন আপনি Pattern Matching বা Multiple conditions নিয়ে কাজ করবেন, তখন Guards সবচেয়ে কার্যকরী পদ্ধতি হিসেবে কাজ করে।

Content added By
Promotion
NEW SATT AI এখন আপনাকে সাহায্য করতে পারে।

Are you sure to start over?

Loading...